package com.example.chamberlainserver.mapper;

import com.example.chamberlainserver.Entry.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * 用户数据访问接口
 */
@Mapper
public interface UserMapper {
    /**
     * 根据ID查询用户
     */
    User getUserById(@Param("id") Integer id);
    
    /**
     * 根据学号查询用户
     */
    User getUserByStuNo(@Param("stuNo") String stuNo);

    /**
     * 根据手机号查询用户
     */
    User findByPhone(@Param("phone") String phone);
    
    /**
     * 查询所有用户
     */
    List<User> getAllUsers();
    
    /**
     * 根据角色查询用户
     */
    List<User> getUsersByRole(@Param("role") String role);
    
    /**
     * 新增用户
     */
    int insertUser(User user);
    
    /**
     * 更新用户
     */
    int updateUser(User user);

    
    /**
     * 删除用户
     */
    int deleteUserById(@Param("id") Integer id);
    
    /**
     * 分页查询用户列表
     * @param params 查询参数
     * @return 用户列表
     */
    List<User> getPagedUserList(Map<String, Object> params);
    
    /**
     * 获取分页查询的总记录数
     * @param params 查询参数
     * @return 总记录数
     */
    Long getPagedUserCount(Map<String, Object> params);
}